<template>
  <div>
    <div id="app" class="wrapper wrapper-content">
      <div class="row">
          <div>
            <div class="panel panel-primary">
                <div class="panel-body" style="padding: 0px 120px; box-sizing: border-box;">
                    <el-form size="small" :model="inputForm" ref="inputForm" v-loading="loading" :disabled="formReadOnly">
                        <div  style="text-align:center">
                            <h3 style="font-weight: bold;color: black;font-size:24px">转正申请单</h3>
                        </div>
                        <table style="margin:0 auto;width:80%;margin-top:20px;border-collapse: collapse;margin-bottom:20px">
                            <tr style="line-height: 3.5;">
                                <td colspan="4"
                                    style="font-weight: bold;text-align: left;padding-left: 32px;position: relative;font-size: 14px">
                                    <img src="../../../../../assets/imgs/processManagement/work.png" alt=""
                                          style="position: absolute;width: 20px;height: 20px;left: 0px;top: 14px;margin-left: 8px">
                                    基本信息
                                </td>
                            </tr>
                            <tr class="iconHidden">
                                <td class="width-15">申请人</td>
                                <td class="width-30" >
                                    <el-form-item  prop="applyuser.id" >
                                          <user-select :limit='1' :value="inputForm.applyuser.id" @getValue='(value) => {inputForm.applyuser.id=value}' disabled></user-select>
                                    </el-form-item> 
                                </td>
                                <td class="width-15" >所属公司</td>
                                <td class="width-30"  >
                                    <el-form-item  prop="coompany.id">
                                    <SelectTree
                                                ref="coompany"
                                                :props="{
                                                    value: 'id',             // ID字段名
                                                    label: 'name',         // 显示名称
                                                    children: 'children'    // 子级字段名
                                                  }"
                                                disabled
                                                url="/sys/office/treeData?type=2"
                                                :value="inputForm.coompany.id"
                                                :clearable="true"
                                                :accordion="true"
                                                @getValue="(value) => {inputForm.coompany.id=value}"/>
                                    </el-form-item>
                                </td>
                            </tr>
                            <tr  class="iconHidden">       
                                <td class="width-15">申请时间</td>
                                <td class="width-30">
                                      <el-form-item prop="applydate">
                                          <el-date-picker
                                                v-model="inputForm.applydate"
                                                type="datetime"
                                                style="width: 100%;"
                                                disabled
                                                value-format="yyyy-MM-dd HH:mm:ss"
                                                placeholder="请选择">
                                              </el-date-picker>
                                    </el-form-item>
                                </td>
                                <td class="width-15">所属部门</td>
                                <td class="width-30">
                                    <el-form-item  prop="depart.id">
                                    <SelectTree
                                                ref="depart"
                                                :props="{
                                                    value: 'id',             // ID字段名
                                                    label: 'name',         // 显示名称
                                                    children: 'children'    // 子级字段名
                                                  }"
                                                disabled
                                                url="/sys/office/treeData?type=2"
                                                :value="inputForm.depart.id"
                                                :clearable="true"
                                                :accordion="true"
                                                @getValue="(value) => {inputForm.depart.id=value}"/>
                                    </el-form-item>   
                                </td>
                            </tr>
                            <tr class="iconHidden">
                                <td class="width-15">入职日期</td>
                                  <td class="width-30">
                                      <el-form-item  prop="incomedate">
                                        <el-date-picker
                                              v-model="inputForm.incomedate"
                                              type="date"
                                              style="width: 100%;"                                         
                                              value-format="yyyy-MM-dd"
                                              placeholder="请选择">
                                            </el-date-picker>
                                  </el-form-item>
                                </td>
                                <td class="width-15"><span style="color: red">*&nbsp;</span>试用期开始时间</td>
                                <td class="width-30">
                                    <el-form-item  prop="startprobationdate"  :rules="[{required: true, message:'试用期开始时间不能为空', trigger:'blur'}]">
                                          <el-date-picker
                                                v-model="inputForm.startprobationdate"
                                                type="date"
                                                style="width: 100%;"
                                                value-format="yyyy-MM-dd"                                             
                                                format="yyyy-MM-dd"  
                                                @change="timeCondition"
                                                placeholder="请选择">
                                              </el-date-picker>
                                    </el-form-item>
                                </td>      
                            </tr>
                              <tr  class="iconHidden">
                                <td class="width-15"><span style="color: red">*&nbsp;</span>试用期结束时间</td>
                                <td class="width-30">
                                    <el-form-item  prop="endprobationdate"   :rules="[{required: true, message:'试用期结束时间不能为空', trigger:'blur'}]">
                                          <el-date-picker
                                                v-model="inputForm.endprobationdate"
                                                type="date"
                                                style="width: 100%;"
                                                @change="timeCondition"                                             
                                                value-format="yyyy-MM-dd"
                                                format="yyyy-MM-dd"
                                                placeholder="请选择">
                                              </el-date-picker>
                                    </el-form-item>
                                </td>
                                <td class="width-15"></td>
                                <td class="width-30"> 
                                </td>
                            </tr>
                            <tr style="line-height: 3.5;">
                                <td colspan="4"
                                    style="font-weight: bold;text-align: left;padding-left: 32px;position: relative;font-size: 14px">
                                    <img src="../../../../../assets/imgs/processManagement/basic.png" alt=""
                                          style="position: absolute;width: 20px;height: 20px;left: 0px;top: 14px;margin-left: 8px">
                                    综合描述
                                </td>
                            </tr>
                            <tr class="iconHidden iconHiddenPadding">
                                <td class="width-15"><span style="color: red">*&nbsp;</span>工作感想及建议</td>
                                <td colspan="4">
                                    <el-form-item prop="worksuggestion"  :rules="[{required: true, message:'请填写工作感想及建议', trigger:'blur'}]">
                                      <el-input  v-model="inputForm.worksuggestion"  ></el-input>
                                    </el-form-item>
                                </td>
                            </tr>
                            <tr class="iconHidden iconHiddenPadding">
                                <td class="width-15">个人发展规划</td>
                                <td colspan="4">
                                    <el-form-item prop="workplan">
                                      <el-input  v-model="inputForm.workplan"  ></el-input>
                                    </el-form-item>
                                </td>
                            </tr>
                            <tr class="iconHidden iconHiddenPadding">
                                <td class="width-15">工作目标</td>
                                <td colspan="4">
                                    <el-form-item prop="workarm">
                                      <el-input  v-model="inputForm.workarm"  ></el-input>
                                    </el-form-item>
                                </td>
                            </tr>
                            <tr class="iconHidden">
                                <td class="width-15">附件</td>
                                <td colspan="4" style="position:relative;">
                                  <!-- :on-preview="handlePreview" -->
                                    <el-upload ref="fujian"  
                                      :action="`${this.$http.BASE_URL}/sys/file/webupload/upload?uploadPath=/dlyrl/oa/applyregular/oaApplyRegular`"
                                      :headers="{token: $cookie.get('token')}"                                     
                                      :on-preview="(file) => {$window.open ((file.response && file.response.url) || file.url,'_blank') }"
                                      :on-success="(response, file, fileList) => {
                                        inputForm.fujian = fileList.map(item => (item.response && item.response.url) || item.url).join('|')
                                      }"
                                      :on-remove="(file, fileList) => {
                                        $http.post(`/sys/file/webupload/deleteByUrl?url=${(file.response && file.response.url) || file.url}`).then(({data}) => {
                                          $message.success(data.msg)
                                        })
                                        inputForm.fujian = fileList.map(item => item.url).join('|')
                                      }"
                                      :before-remove="(file, fileList) => {
                                        return $confirm(`确定移除 ${file.name}？`)
                                      }"
                                      multiple
                                      :limit="5"
                                      :on-exceed="(files, fileList) =>{
                                        $message.warning(`当前限制选择 5 个文件，本次选择了 ${files.length} 个文件，共选择了 ${files.length + fileList.length} 个文件`)
                                      }"
                                      :file-list="fujianArra">
                                      <el-button size="small" type="primary" style="position:absolute;right:5px;top:4px;padding:9px"><i class="fa fa-cloud-upload" ></i></el-button>
                                      <!-- <div slot="tip" class="el-upload__tip">添加相关附件</div> -->
                                    </el-upload>
                                </td>
                            </tr>
                        </table>
                    </el-form>                
                </div>
            </div>
          </div>
      </div>
    </div>
  </div>
</template>
<script>
  import UserSelect from '@/components/userSelect'
  import SelectTree from '@/components/treeSelect/treeSelect.vue'
  import tableStyles from '../../../../../utils/mixins'
  export default {
    mixins: [tableStyles],
    data () {
      return {
        title: '',
        method: '',
        loading: false,
        fujianArra: [],
        inputForm: {
          id: '',
          applyuser: {
            id: ''
          },
          applydate: '',
          coompany: {
            id: ''
          },
          incomedate: '',
          depart: {
            id: ''
          },
          startprobationdate: '',
          endprobationdate: '',
          worksuggestion: '',
          workplan: '',
          workarm: '',
          fujian: ''
        },
      }
    },
    props: {
      businessId: {
        type: String,
        default: ''
      },
      formReadOnly: {
        type: Boolean,
        default: false
      }
    },
    components: {
      UserSelect,
      SelectTree
    },
    watch: {
      'businessId': {
        handler (newVal) {
          if (this.businessId) {
            this.init(this.businessId)
          } else {
            this.$nextTick(() => {
              this.$refs.inputForm.resetFields();
              if(this.$store.state.user.id!=''){
                var users=this.$store.state.user
              }else{
                var users=JSON.parse(sessionStorage.getItem("userInfo"));
              }
              this.inputForm.applyuser.id=users.id;
              this.inputForm.coompany.id=users.company.id;
              this.inputForm.depart.id=users.office.id;
              this.inputForm.applydate=this.getNowTime();
            })
          }
        },
        immediate: true,
        deep: false
      }
    },
    created(){
      window.addEventListener("beforeunload",()=>{
        sessionStorage.setItem("userInfo",JSON.stringify(this.$store.state.user))
      })
    },
    methods: {
      //时间选择的判断条件
      timeCondition(){
        if(this.inputForm.startprobationdate.length!=0&&this.inputForm.endprobationdate.length!=0){
          var startDate=new Date(this.inputForm.startprobationdate);
          var endDate=new Date(this.inputForm.endprobationdate);
          if(startDate>endDate){
            this.$message.warning('开始时间不能大于结束时间');
            this.inputForm.endprobationdate='';
            return false
          }  
        }
      },
      init (id) {
        this.fujianArra = []
        if (id) {
          this.loading = true
          this.inputForm.id = id
          this.$nextTick(() => {
            this.$refs.inputForm.resetFields()
            this.$http({
              url: `/dlyrl/oa/applyregular/oaApplyRegular/queryById?id=${this.inputForm.id}`,
              method: 'get'
            }).then(({data}) => {
              this.inputForm = this.recover(this.inputForm, data.oaApplyRegular)
              this.inputForm.fujian.split('|').forEach((item) => {
                if (item.trim().length > 0) {
                  this.fujianArra.push({name: decodeURIComponent(item.substring(item.lastIndexOf('/') + 1)), url: item})
                }
              })
              this.loading = false;             
            })
          })
        }
      },
      //回显文件点击下载功能
      handlePreview(file) {
        // console.log(file.url);
        document.location.href = file.url
      },
      // 表单提交
      saveForm (callback) {
        this.$refs['inputForm'].validate((valid) => {
          if (valid) {
            this.loading = true
            this.$http({
              url: `/dlyrl/oa/applyregular/oaApplyRegular/save`,
              method: 'post',
              data: this.inputForm
            }).then(({data}) => {
              if (data && data.success) {
                callback(data.businessTable, data.businessId);
                this.loading = false;
                this.$refs.inputForm.resetFields();
                this.inputForm.applyuser.id=this.$store.state.user.id;
                this.inputForm.coompany.id=this.$store.state.user.company.id;
                this.inputForm.depart.id=this.$store.state.user.office.id;
                this.inputForm.applydate= this.getNowTime();
                this.fujianArra=[];
              }
            })
          }
        })
      }
    }
  }
</script>